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(57) Methode et appareil permettant une 
connexion trois voies entre un dispositif 
informatique mobile, un dispositif informatique 
stationnaire et un reseau informatique. Lorsqu'une 
connexion existe entre un dispositif informatique 
mobile (p. ex. un bloc-notes electronique) et le dispositif 



(57) A method and apparatus for providing a three-way 
connection between a mobile computing device, a 
stationary computing device and a computer network. 
When there is an established connection between a 
mobile computing device (e.g. a notebook computer) and 
the stationary computing device (e.g. desktop PC) over 
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informatique stalionnaire (p. ex. micro-ordinateur de 
bureau) sur le canal de communication sans fil 
(p. ex. liaison ml'raronge), le s\ steme fonetionne en 
mode BRIDGE (passerelle). En mode BRIDGE, le 
systeme reachemine les paquets d'information dans la 
couche OSI 2 (couche liaison de donnees). I.orsqu un 
bloc-notes electronique n'y est pas raccorde, le systeme 
fonetionne en mode PASSTHROUGH (direct) et tout le 
Irafic de messages nun diffuses pro\ enant du reseau local 
Ethernet est filtre par l'adaptateur Ethernet selon 
l'adresse de reseau ou l'adresse de groupe du micro- 
ordinateur de bureau. 



the wireless communication channel (e.g. infrared link), 
the system operates in BRIDGE mode. In BRIDGE 
mode the system redirects information packets in the OSI 
layer 2 (data link layer). When a notebook computer is 
not attached, the system operates in PASSTHROUGH 
mode and all non-broadcast message traffic from the 
Ethernet LAN is filtered by the Ethernet adapter 
based on the network address or group address of the 
desktop PC. 
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ABSTRACT OF THE DISCLOSURE 



A method and apparatus for providing a three-way connection between a 
mobile computing device, a stationary computing device and a computer network. 
When there is an established connection between a mobile computing device (e.g. 
a notebook computer) and the stationary computing device (e.g. desktop PC) 
over the wireless communication channel (e.g. infrared link), the system 
operates in BRIDGE mode. In BRIDGE mode the system redirects information 
packets in the OSI layer 2 (data link layer). When a notebook computer is not 
attached, the system operates in PASSTHROUGH mode and all non-broadcast 
message traffic from the Ethernet LAN is filtered by the Ethernet adapter based 
on the network address or group address of the desktop PC. 
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METHOD AND APPARATUS FOR PROVIDING 
A 3 -WAY CONNECTION BETWEEN A MOBILE COMPUTING DEVICE, A 
STATIONARY COMPUTING DEVICE AND A COMPUTER NETWORK 

Field of the Invention 

5 The present invention relates to computer networking, and in particular 

to a method and apparatus for providing a three-way connection between a 
mobile computing device , a stationary computing device and a computer network . 

Background of the Invention 

Local area networks (LANs) have historically consisted of nodes 
10 interconnected by physical telecommunications media (e.g. coaxial cable, twisted 
pair wire or fibre optics). 

Recently wireless LANs, the nodes of which are not connected by means 
of a physical medium, have started to appear in the art. These wireless LANs 
communicate by means of an infrared (IR), radio or other signals. One of the 
15 benefits of using wireless lANs is that cabling is not required. This is 
particularly useful for mobile nodes such as laptop and notebook computers, 
PDAs (Personal Digital Assistants), and the like. If appropriately equipped with 
a suitable wireless adapter (which includes a transmitter/ receiver and control 
card), such as an IR wireless adapter, the mobile nodes can move around and 
20 remain connected to the network, provided they do not move out of range for 
the IR adapter. 

To accomplish a simultaneous three-way connection between a notebook PC, 
a desktop PC and a LAN, there are two possible approaches. The first approach 
involves using a router. The Network Operating System (NOS) of the desktop 
25 PC is provided with a built-in router program and connected to the Network 
Operating System (NOS) on the LAN. The NOS of the notebook PC is connected 
to the router program within the desktop PC NOS. Data in the form of 
information packets from the NOS of the notebook PC destined for either the 
NOS of the desktop PC or the NOS on the LAN is first received by the router 
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program on the NOS of the desktop PC. Based on the destination information 
contained in the data packet, the router will either send the data packet to the 
NOS of the desktop PC or to NOS on the LAN. 

The second approach involves using a three-way bridge. The NOS of the 
5 desktop PC is directly connected to the three-way bridge program on the 
desktop PC. The NOS of the notebook PC is directly connected to the same 
three-way bridge program. The NOS on the LAN is also directly connected to 
the same three-way bridge program. 

The main difference between the router and the three-way bridge is that 
10 the router redirects data in the OSI (Open System Interconnection Standard) 
layer 3, i.e. the network layer, and the three-way bridge redirects data in the 
OSI layer 2, i.e. the data link layer. 

The three-way bridge is preferred in a specific environment having only 
one notebook PC, one desktop PC, and a LAN. The three-way bridge is 
15 preferred over a router due to its simplicity in setting up the connections, 
operation by the end -use, and the ease of implementation. 



Summary of the Invention 

The present invention provides a method and apparatus for providing a 
three-way bridge or mobile support means or program (MSP) for coupling a 
2 0 mobile PC to a desktop PC and a wired computer network. 

According to one aspect of the invention, the three-way bridge comprises 
a program running on the desktop PC that appears as a LAN hardware adapter 
device driver to the Network Operating System (NOS) of the desktop PC. The 
desktop PC NOS assumes it is communicating with the LAN hardware adapter 
25 directly. 

The three-way bridge according to the present invention runs on top of 
both the device driver for the wireless interface adapter and the device driver 
for the LAN adapter. The three-way bridge appears as a NOS to both the 
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wireless interface adapter and the LAN hardware adapter. When all the 
connections between the notebook PC, the desktop PC, and the LAN are active 
simultaneously, the three-way bridge according to the present invention puts 
both the wireless adapter and the LAN adapter into a promiscuous mode. During 
5 initialization, the three-way bridge will discover the node address of the LAN 

hardware adapter. This address is used by the NOS on the desktop PC. To 
discover the node address of the notebook PC NOS, the three-way bridge 
program examines the first data that is originated from the notebook PC. The 
program checks the source address and the OSI (Open System Interconnection 
10 Standard) layer 2 data link layer to determine the node address of the NOS for 

the notebook PC. 

In operation, all traffic originating from the NOS of the notebook PC is 
received by the three-way bridge program. The three-way bridge program 
checks the destination address in the OSI layer 2 (i.e. the data link layer) to 

15 determine if the data is destined for the NOS of the desktop PC. If the data 

is destined for the desktop PC NOS, the data is delivered to the desktop PC 
NOS as though it came from the LAN. If the data is intended for both the 
desktop PC and the LAN, e.g. broadcast frames, the data is sent to the LAN 
in addition to the desktop PC. If the data is intended for the LAN, the data 

2 0 is sent on to the LAN. 

It is a feature of the three-way bridge program that all traffic on 
the LAN is examined. The three-way bridge program checks the destination 
address in the OSI layer 2, i.e. the data link layer, to determine if the data is 
destined for the desktop PC NOS or the notebook PC NOS, or both. If the data 

25 is not destined to the desktop PC NOS or the notebook PC NOS, the three-way 

bridge program takes no further action. If the data is destined to the desktop 
PC NOS or the notebook PC NOS, or both, the three-way bridge program, 
depending on the destination address, sends the data either to the desktop PC 
NOS or the notebook PC NOS, or both. 

30 The traffic originating from the desktop PC NOS is also examined by the 

three-way bridge program. The bridge program checks the destination address 
in the OSI layer 2 data link layer to determine if the data is destined for the 
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notebook PC NOS or NOS on the LAN, or both. If the data is destined for the 
notebook PC NOS only, the bridge program sends the data to the notebook PC. 
On the other hand, if the data is destined for the NOS on the LAN, the three- 
way bridge program sends the data on to the LAN. If the data is destined for 
5 both the notebook PC NOS and the NOS on the LAN , the program sends the data 
to both the notebook PC as well as the NOS on the LAN. 

In a further enhancement, the three-way bridge program according to the 
present invention will re -program the LAN adapter to take it out of promiscuous 
mode and put it back into normal mode with the original node address in order 

10 to obtain optimal performance when the notebook PC is not connected to the 
desktop PC. In normal mode, the LAN adapter hardware will filter out all the 
data that is not directed to the node address. In this situation, the three-way 
bridge program does not need to spend CPU cycles to perform the filtering. 
The desktop PC with the three-way bridge program should perform as well as 

15 one without the three-way bridge program. 

In a first aspect, the present invention provides an apparatus for 
providing a three-way connection between a computer network, a stationary 
computing device, and a mobile computing device, said apparatus comprising: (a) 
network interface means for interfacing to said computer network; (b) a network 

20 operating system on said stationary computing device and including means for 
processing information packets for and from said computer network ;(c) 
communication interface means for communicating between said stationary 
computing device and said mobile computing device and including control means 
for transmitting and receiving information packets between said stationary 

25 computing device and said mobile computing device; (d) routing means for 
routing information packets between said computer network, said stationary 
computing device, and said mobile computing device, said routing means 
including detector means for detecting connection of a mobile computing device 
to said communication interface means, and having redirector means responsive 

3 0 to a connection to said mobile computing device for redirecting information 
packets between said computer network, said stationary computing device and 
said mobile computing device. 
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In a second aspect of the present invention, there is provided a method 
for providing a three-way connection for transferring information packets 
between a stationary computing device, a mobile computing device, and a 
network, said stationary computing device being coupled to said network through 
a network adapter, and said mobile computing device utilizing a wireless 
communication channel for transferring information packets to said stationary 
computing device, said method comprising the steps of: (a) determining if said 
mobile computing device is coupled to said stationary computing device via said 
wireless communication channel; (b) redirecting information packets originating 
from said mobile computing device and destined for said network through said 
stationary computing device when said wireless communication channel is active 
as determined in step (a); (c) redirecting information packets originating from 
said network and destined for said mobile computing device through said 
stationary computing device when said wireless communication channel is active 
as determined in step (a) . 

In another aspect of the present invention, there is provided a computer 
program product for use in a computer system comprising a stationary computing 
device, a mobile computing device and a network, said stationary computing 
device being coupled to said network and having a network operating system, 
and said mobile computing device utilizing a wireless communication channel for 
transferring information packets to said stationary computing device, said 
computer program product comprising: a recording medium; means recorded on 
said medium for instructing said stationary computing device to perform the 
steps of: (a) determining if said mobile computing device is coupled to said 
stationary computing device via said wireless communication channel; (b) 
redirecting information packets originating from said mobile computing device and 
destined for said network through said stationary computing device when said 
wireless communication channel is active as determined in step (a); (c) 
redirecting information packets originating from said network and destined for 
said mobile computing device through said stationary computing device when said 
wireless communication channel is active as determined in step (a) . 
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Brief Description of the Drawing s 

Reference will now be made to the accompanying drawings which show, by 
way of example, a preferred embodiment of the present invention, and in which: 

Fig. 1 shows in block diagram form a mobile support program according 
to the present invention; 

Fig. 2 shows in schematic form a configuration for providing a mobile PC 
with access to a wired computer network utilizing the mobile support program 
according to the present invention; 

Fig. 3 shows in schematic form another configuration for integrating a 
mobile PC with a desktop PC; 

Fig. 4 shows in schematic form another configuration for providing a 
desktop PC with access to a wired computer network utilizing the mobile support 
program; and 

Fig. 5 shows in schematic form another configuration for allowing a mobile 
PC to roam between desktop PC's utilizing the mobile support program according 
to the present invention. 

Detailed Description of the Preferred Embodiment 

The present invention provides a method and means for connecting a 
mobile or portable personal computer, referred to as a mobile PC, to a stationary 
or desktop PC. The desktop PC is coupled to a wired computer network. 

In the drawings, the wired computer network is denoted by reference 10, 
the desktop PC is denoted by reference 12, referred to individually as 12-1 and 
12-2 in Fig. 5, and the mobile PC is denoted by reference 14. The mobile PC 
is described as a notebook or laptop computer, but may comprise other mobile 
computing devices, such as, a personal digital assistant (PDA), a personal 
communication assistant (PCA), an electronic organizer or a two-way interactive 
TV/set-top box remote control. In the described system, the wired computer 
network 10 comprises a Local Area Network or LAN and is referred to as a wired 
LAN. It is, however, to be understood that other types of wired computer 
networks are possible, for example, including an ATM network or a cable TV 
network. 
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Data transmission over the LAN 10 is performed according to well defined 
and internationally accepted protocol standards. In the present description, the 
LAN 10 is described (but not limited) in relation to known communication protocol 
according to the Ethernet standard as will be within the understanding of those 
skilled in the art. Other protocols, such as, token ring, are also applicable and 
within the understanding of those skilled in the art. 

As will be familiar to those skilled in the art, an Ethernet frame, i.e. 
information packet, according to the MAC-layer (Medium Access Control) protocol 
comprises 7 bytes preamble, 1 byte frame delimiter, 6 bytes of information 
representing the source address, that is, the address of the originating or 
transmitting node, for the information packet, 6 bytes of information 
representing the destination address for the information packet, 2 bytes for 
packet length/type, 46 to 1500 bytes of data, and 4 bytes FCS. The 
arrangement of the various bits of information within the MAC-layer header has 
been standardized and is well-known to those skilled in the art. 

As shown in Fig. 2, the mobile PC 14 is coupled to the desktop PC 12 
through a wireless communication channel 16. In the described system, the 
wireless communication channel 16 comprises an infrared communication channel, 
although it is understood that other types of wireless communication links are 
possible. The implementation of the infrared channel 16 is within the 
understanding of those skilled in the art using, for example, conventional IrDA 
chipsets, such as the IBM1502 IR controller chip from IBM Corp., or the 
NSC108IR controller chip from National Semiconductor Corp. 

In the description that follows, the following definitions are used. Local 
area network (LAN) is a network that is usually confined to a small geographical 
area, e.g. within a building. IR WLAN is a wireless LAN, i.e. WLAN, that uses 
infrared light as the communication medium. Mobile personal computer (MPC) 
means any mobile device that has a IrDA 1.1 compatible infrared device. 
Desktop personal computer (DPC) means any desktop device that has an IrDA 
1.1 compatible infrared device. Access point (AP) means a device that connects 
a mobile PC to a wired LAN using a wireless infrared connection between the 
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access point and the mobile PC. Bridge means a bridge that operates at the OSI 
data link layer (i.e. layer 2) and copies frames from one network to the other. 
The bridge often contains logic to copy only a subset of the frames it receives. 
This logic is known as filtering. A bridge is usually measured by its filtering 
rate and forwarding rate. 

The wired LAN 10 includes connections or nodes for other terminals 
comprising a file server 18, a print server 20, and a host computer system 22. 
The file server 18, print server 20 and host computer 22 provide resources 
which can be shared between the mobile PC 14, the desktop PC 12 and other 
stations (e.g. mobile or desktop PC's) connected to the LAN 10. The file server 
18 includes mass storage devices (not shown) for providing file archival and 
retrieval. As shown in Fig. 2 (and Fig. 4), the print server 20 includes a 
printer 24 for providing a printing resource for the network 10. 

The method and means according to the present invention allows a mobile 
PC 14 to connect to an Ethernet wired LAN 10 via an existing desktop PC 12, 
thereby eliminating the need to purchase an additional access point (AP) or 
station box (not shown) for the mobile PC 14. In this mode, the mobile PC 14 
is provided with access to the resources, e.g. file server 18 or the printer 24 
on the network 10. The user of the mobile PC 14 may require access to the 
Ethernet wired LAN 10 for the host computer 22, the file server 18, the printer 
24, etc. According to the present invention, the user can accomplish the 
connection via the desktop PC 12 using the wireless infra-red communication link 
16 between the mobile PC 14 and the desktop PC 12. 

In another aspect, the present method allows the mobile PC 14 to connect 
to the desktop PC 12 to provide the mobile PC 14 with access to the resources 
of the desktop PC 12, for example, a printer 26 as shown in Fig. 3 or a mass 
storage device. This feature is particularly useful to provide a connection 
between the mobile PC 14 and the desktop PC 12 in order to synchronize files 
and/or databases. 
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In another aspect, the method according to the present invention allows 
the desktop PC 12 to remain connected to the wired LAN 10 while the mobile PC 
14 accesses the network 10 through the desktop PC 12. This aspect is depicted 
in Fig. 2. 

In another aspect, the method according to the present invention allows 
the mobile PC 14 to roam between desktop PC's 12-1 and 12-2 located on the 
same Ethernet LAN segment as illustrated in Fig. 5. This mode of operation and 
the others shown in Figs. 2 to 4 are described in more detail below. 

Reference is made to Fig. 1 which shows in block diagram form an 
implementation for the method and means according to the present invention. 
The method and means are embodied in computer software denoted generally by 
100 and computer hardware 50 which runs on the desktop PC 12. The software 
100 runs the hardware 50 which couples the desktop PC 12 to the Ethernet LAN 
10 and the wireless communication channel 16. The computer software 100 
comprises the workstation software for the Network Operating System or NOS. 

The hardware 50 comprises a network adapter 52 and a wireless adapter 
54. For an Ethernet based configuration, the network adapter 52 comprises 
suitable Ethernet hardware which is coupled to the Ethernet LAN 10. For an 
infrared communication channel 16, the wireless adapter 54 comprises IrDA 1.1 
hardware as will be familiar to one skilled in the art. The mobile PC 14 has a 
corresponding IrDA controller and device driver (not shown) for implementing 
the communication channel 16. 

As shown in Fig. 1, the workstation software 100 includes an Ethernet 
device driver 102 and an IrDA device driver 104. The Ethernet device driver 
102 interfaces the workstation software 100 to the Ethernet adapter 52 and the 
IrDA device driver 104 interfaces the workstation 100 to the IrDA 1.1 adapter 
54. In known manner, the Ethernet device driver 102 provides the workstation 
software 100 with the capability to work with the specific Ethernet adapter 52 
and perform data transmission on the LAN 10. Similarly, the IrDA device driver 
104 allows the workstation software to transmit and receive information packets 
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over the wireless communication channel 16 through the IrDA adapter 54. In the 
described embodiment, each adapter 52, 54 comprises a NDIS type driver as will 
be understood by those skilled in the art. 

Referring to Fig. 1, the workstation software 100 preferably includes 
upper layer protocol stacks 106 which support communication protocols for known 
Network Operating Systems (NOS). There is provided an upper layer protocol 
stack 106-1 for TCP/IP (Transmission Control Protocol/ Internet Protocol) 106, 
an upper layer protocol stack 106-2 for NETBIOS LAN Requester, an upper layer 
protocol stack 106-3 for SNA 3270, and an upper layer protocol stack 106-4 for 
NETWARE. 112. The upper layer protocol stacks 106 comprise software which 
will be well understood by one skilled in the art. 

According to the invention, workstation software 100 includes another 
device driver 110. As shown in Fig. 1, the device driver 110 binds itself to the 
upper layer protocol stack 106. The device driver 110 also binds itself to the 
Ethernet device driver 102 and the IrDA device driver 104. 

The device driver 110 is implemented to mimic the behaviour of a NDIS2 
device driver in the described embodiment. According to the invention, the 
device driver 110 takes on two personas. First, the device driver 110 appears 
to the upper layer protocol stack 106, e.g. TCP/IP 106-1, as an Ethernet NDIS2 
device driver. On the other hand, for Ethernet device driver 102 and the IrDA 
device driver 104, the device driver 110 appears as an upper layer protocol 
stack 106. 

The device driver 110 according to the present invention operates in two 
modes: BRIDGE mode and PASSTHROUGH mode. The mode of operation depends 
on whether the mobile PC 14 lias established a wireless infrared connection with 
the desktop PC 12. The device driver 110 determines if a connection has been 
established by querying the MAC (Medium Access Control) statistics for the IrDA 
device driver 104. A specific field in the MAC statistics for the IrDA driver 104 
serves to indicate whether an IrDA connection over the channel 16 exists. 
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If there is an established connection over the wireless, i.e. infrared, 
communication channel 1G between the mobile PC 14 and the desktop PC 12, the 
device driver 110 operates in BRIDGE mode. In BRIDGE mode, the device 
driver 110 functions as an Ethernet transparent MAC-bridge that connects the 
mobile PC 14 to the Ethernet wired LAN 10 via the desktop PC 12. The device 
driver 110 also acts as an Ethernet transparent MAC-bridge that connects the 
desktop PC 12 to the Ethernet wired LAN 10. 

In the BRIDGE mode of operation, the device driver 110 puts both the 
Ethernet adapter 52 and the IrDA adapter 54 into "promiscuous" mode. In 
promiscuous mode, the adapters 52, 54 receive all information packets regardless 
of the destination address. In BRIDGE mode, the device driver 110 resends on 
the Ethernet LAN 10 any IR message received from the mobile PC 14 which is 
destined for a wired node, e.g. to the file server 18. On the other hand, an 
IR information packet received from the mobile PC 14 and intended for the 
desktop PC 12 is forwarded by the device driver 110 to the upper layer protocol 
stack 106 that is binded to the device driver 110. 

Information packets originating from the desktop PC 12 are handled as 
follows by the device driver 110 in BRIDGE mode. The device driver 110 sends 
any information packets destined for a wired node, e.g. print server 20, on the 
LAN 10 and the packets are sent on the LAN 10 by the device driver 110 via the 
Ethernet device driver 102. Any information packet from the desktop PC 12 
destined for the mobile PC 14 is sent by the device driver 110 on the wireless 
communication channel 16 via the IrDA device driver 104. 

Information packets originating from the Ethernet LAN 10 are routed by 
the device driver 110 as follows in BRIDGE mode. Any information packet 
received from the Ethernet LAN 10 and destined for the desktop PC 12 is 
forwarded by the device driver 110 to the upper layer protocol stack 106 that 
is binded to the device driver 110 (provided such a stack exists). An 
information packet received from the LAN 10 and destined to the mobile PC 14 
is resent by the device driver 110 on the wireless communication channel 16 via 
the IrDA adapter 54. 
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It will be appreciated that the device driver according to the present 
invention is not a standard-compliant ethernet MAC-bridge implementation. 
Rather, the primary function of the device driver 110 according to the present 
invention is to create a three-way connection between the Ethernet LAN 10, the 
desktop PC 12, and the mobile PC 14. 

The device driver 110 operates in PASSTIIROUGH mode when there is no 
mobile PC 14 connected to the desktop PC 12. In the PASSTHROUGH mode of 
operation, the device driver 110 puts the Ethernet adapter 52 back into NORMAL 
mode, i.e. to the preset universal or assigned network address and group 
address. The device driver 110 however keeps the IrDA adapter 54 in 
promiscuous mode. 

In PASSTHROUGH mode, the Ethernet adapter 52 filters out all non- 
broadcast message traffic from the Ethernet LAN 10 that is not destined for its 
network address or group address. The device driver 110 passes all data 
packets received from the Ethernet adapter 52 to the upper layer protocol stack 
116. In PASSTHROUGH mode, the device driver 110 does not examine or act on 
the data except for the following commands from the upper layer protocol stack: 
(1) Open_Adapter; (2) Close_Adapter; (3) Set_Station_Address ; (4) 
Add_Multicast_Address ; (5) Delete Multicast Address . 

The device driver 110 is configured not to pass the Open Adapter command 
to the Ethernet hardware adapter 52. Instead, the device driver 110 returns 
an "Okay" indication to the upper layer protocol stack 10G. Similarly, the 
device driver 110 does not pass the Close Adapter command to the Ethernet 
adapter 54. Instead, the device driver 110 returns an Okay indication to the 
upper layer protocol stack 106. 

The device driver 110 processes the Set_Station_Address command 
according to its mode of operation. In BRIDGE mode, the device driver 110 does 
not pass the Set_Station_Address command to the Ethernet adapter 52. Instead, 
the device driver 110 stores the station_address in memory and returns an Okay 
indication to the upper protocol stack 106. When the device driver 110 switches 
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to PASSTHROUGH mode, it sets the Ethernet adapter 52 based on the 
station_address. In PASSTHROUGH mode, the device driver 110 passes the 
Set Station Address command to the Ethernet adapter 52. The device driver 110 
also stores the station_address in memory. If the indication from the Ethernet 
adapter 52 is not okay, the device driver 110 deletes the station_address from 
its memory. 

The device driver 110 processes the Add Multicast Address command 
differently depending on its mode of operation. In BRIDGE mode, the device 
driver 110 does not pass the Add_Multicast_Address command to the Ethernet 
adapter 52. Instead, the device driver 110 stores the multicastaddress in 
memory and returns an Okay indication to the Ethernet adapter 52. When the 
device driver 110 switches to PASSTHROUGH mode, the device driver 110 sets 
the Ethernet adapter 52 based on the multicast_ad dress . In PASSTHROUGH 
mode, the device driver 110 passes the Add_Multicast_Address command to the 
Ethernet adapter 52. The device driver 110 also stores the multicast address 
in memory. If the indication received from the Ethernet adapter 52 is not ok, 
the device driver 110 deletes the multicast_ad dress from memory. 

Processing of the Delete Multicast Address also depends on the mode of 
operation for the device driver 110. In BRIDGE mode, the device driver 110 
does not pass the Delete_Multicast_Addrcss command to the Ethernet adapter 52. 
Instead, the device driver 110 deletes the multicastaddress in memory and 
returns an Okay indication to the Ethernet adapter 52. In PASSTHROUGH mode, 
the device driver 110 passes the Delete_Multicast_Ad dress command to the 
Ethernet adapter 52. If the indication from the Ethernet adapter 52 is okay, the 
device driver 110 deletes the multicast_address from its memory. 

In another aspect, the device driver 110 provides roaming support. When 
the device driver 110 receives the first message from a mobile PC 14 after a new 
infrared connection has been established on the communication link 16, the 
device driver 110 stores the network address of the mobile PC 14 in memory. 
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In some situations, the device driver 110 will lose network data packets 
from the desktop PC 12 in the Ethernet wired LAN 10 to the mobile PC 14, for 
example , if the mobile PC 14 roams from one desktop PC 12-1 to another desktop 
PC 12-2 as illustrated in Fig. 5. However, the device driver 110 will not cause 
duplication in the transmission or reception of network data packets . If network 
data packets are lost, the recovery is performed by the upper layer protocol(s) 
106. 



It is a feature of the present invention that the IrDA NDIS2 device 104 is 
modified to include a new entry in the MAC statistics to indicate whether an 

10 infrared connection has been established on the communication channel 16. The 
device driver 110 uses the MAC entry to determine if a mobile PC 14 is 
connected to the desktop PC 12. 

Since the IrDA adapter 54 will have a lower data transfer rate (4MBPS or 
lower) than the Ethernet adapter 52 (10MBPS), preferably the IrDA adapter 54 

15 will have a higher priority than the Ethernet adapter 52 for handling hardware 
interrupts. In other words, the IrDA adapter 54 should occupy a lower 
interrupt level than the Ethernet adapter 52, as will be understood by those 
skilled in the art. Furthermore, the implementation of the device driver 110 will 
depend on the availability of both the Ethernet NDIS2 device driver 102 and the 

20 IrDA NDIS2 device driver 104 for the desktop PC 12. The device driver 110 
also depends on the availability of either the IrDA NDIS2 device driver 104 or 
the IrDA device driver (not shown) on the mobile PC 14. 

Summarizing, the present invention provides a method and means for a 
three-way bridge which is suitable for known network protocols, such as, 

25 TCP/IP, NetBios™, Netware™, and SNA™. When there is an established 
connection between a mobile computing device (e.g. a notebook computer) and 
the stationary computing device (e.g. desktop PC) over the wireless 
communication channel (e.g. infrared link), the system operates in BRIDGE 
mode. In BRIDGE mode the system redirects information packets in the OSI 

3 0 layer 2 (data link layer). When a notebook computer is not attached, the system 
operates in PASSTHROUGH mode and all non -broadcast message traffic from the 
Ethernet 
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LAN is filtered by the Ethernet adapter based on the network address or group 
address of the desktop PC. 

The present invention may be embodied in other specific forms without 
departing from the spirit or central characteristics thereof. Therefore, the 
presently discussed embodiments are considered to be illustrative and not 
restrictive, the scope of the invention being indicated by the appended claims 
rather than the foregoing description, and all changes which come within the 
meaning and range of" equivalency of the claims are therefore intended to be 
embraced therein. 



The embodiments of the invention in which an exclusive property or priviledge 
are defined as follows 

1 1. A system for providing a three-way connection between a computer 

2 network, a stationary computing device, and a mobile computing device, said 

3 system including: 

4 (a) network interface means for interfacing said stationary computer to 

5 said computer network; 

6 (b) a network operating system on said stationary computing device and 

7 including means for processing information packets for and from said 

8 computer network; 

9 (c) communication interface means for communicating between said 

10 stationary computing device and said mobile computing device and 

11 including control means for transmitting and receiving information 

12 packets between said stationary computing device and said mobile 

13 computing device; 

14 (d) routing means for routing information packets between said computer 

15 network, said stationary computing device, and said mobile 

16 computing device, said routing means including detector means for 

17 detecting connection of a mobile computing device to said 

18 communication interface means, and having redirector means 

19 responsive to a connection to said mobile computing device for 

20 redirecting information packets in the Open System Interconnection 

21 standard (OSI) Data Link Layer, Layer 2 between said computer 

22 network, said stationary computing device and said mobile computing 

23 device using said Data Link Layer. 

1 2. In the system as claimed, in claim 1, wherein said routing means operates 

2 in passthrough mode and bridge mode, and said routing means having means for 

3 selecting bridge mode in response to a mobile computing device being connected 

4 to said stationary computing device. 



1 



3. 



In the system as claimed in claim 2, wherein said routing means provides 
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2 a three-way connection between said computer network, said stationary 

3 computing device, and said mobile computing device when in said bridge mode. 

1 4. In the system as claimed in claim 3, wherein said communication interface 

2 means comprises a wireless adapter and said control means comprises a device 

3 driver compatible with said wireless adapter, and said device driver including 

4 means for interfacing to said routing means. 

1 5. In the system as claimed in claim 3, wherein said network interface means 

2 comprises a network adapter and said means for processing information packets 

3 comprises a device driver compatible with said network adapter , and said device 

4 driver including means for interfacing to said routing means. 

1 6. In the system as claimed in claim 4, wherein said wireless adapter 

2 comprises an infrared adapter and said device driver comprises a NDIS driver. 

1 7. In the system as claimed in claim 5, wherein said network operating 

2 system includes an upper protocol stack, and said upper protocol stack having 

3 means for interfacing to said routing means. 

1 8. In the system as claimed in claim 5 or 7, wherein said network adapter 

2 comprises an Ethernet adapter and said 

3 device driver comprises a NDIS Ethernet driver. 

1 9. In the system as claimed in claim 6, wherein said infrared adapter is an 

2 IrDA hardware adapter. 

1 10. In the system as claimed in claim 1, wherein said routing means includes 

2 control means responsive to a non -active connection between said mobile 

3 computing device and said stationary computing device for operating said 

4 network interface means in filtering mode. 

1 11. A method for providing a three-way connection for transferring information 
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2 packets between a stationary computing device, a mobile computing device, and 

3 a network, said stationary computing device being coupled to said network 

4 through a network adapter, and said mobile computing device utilizing a wireless 

5 communication channel for transferring information packets to said stationary 

6 computing device, said method comprising the steps of: 

7 (a) determining if said mobile computing device is coupled to said 

8 stationary computing device via said wireless communication channel; 

9 (b) redirecting information packets originating from said mobile 

10 computing device and destined for said network through said stationary 

11 computing device using the OSI Standard Layer 2 Data Link Layer when said 

12 wireless communication channel is active as determined in step (a); 

13 (c) redirecting information packets originating from said network and 

14 destined for said mobile computing device through said stationary computing 

15 device using the OSI Standard Layer 2 Data Link Layer when said wireless 

16 communication channel is active as determined in step (a). 

1 12. The method as claimed in claim 11, further including the step of directing 

2 information packets originating from said network to said stationary computing 

3 device when said wireless communication channel is inactive. 

1 13. The method as claimed in claim 12, wherein said step of directing 

2 information packets is performed by said network adapter and comprises filtering 

3 information packets destined for said stationary computing device. 

1 14. The method as claimed in claim 11, wherein said steps (b) and (c) of 

2 redirecting comprises scrutinizing information packets on said network and 

3 selecting information packets destined for said mobile computing device. 

1 15. A computer program product for use in a computer system comprising a 

2 stationary computing device, a mobile computing device and a network, said 

3 stationary computing device being coupled to said network and having a network 

4 operating system, and said mobile computing device utilizing a wireless 

5 communication channel for transferring information packets to said stationary 
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6 computing device, said computer program product comprising: 

7 a recording medium; 

8 means recorded on said medium for instructing said stationary computing 

9 device to perform the steps of: 

10 (a) determining if said mobile computing device is coupled to said 

11 stationary computing device via said wireless communication channel; 

12 (b) redirecting information packets originating from said mobile 

13 computing device and destined for said network through said stationary 

14 computing device using the OSI Standard Layer 2 Data Link Layer when said 

15 wireless communication channel is active as determined in step (a); 

16 (c) redirecting information packets originating from said network and 

17 destined for said mobile computing device through said stationary computing 

18 device using the OSI Standard Layer 2 Data Link Layer when said wireless 

19 communication channel is active as determined in step (a). 

1 16. The computer program product as claimed in claim 15, further including 

2 the step of directing information packets originating from said network to said 

3 stationary computing device when said wireless communication channel is inactive . 

1 17. The computer program product as claimed in claim 16, wherein said step 

2 of directing information packets is performed by said network adapter and 

3 comprises filtering information packets destined for said stationary computing 

4 device . 

1 18. The computer program product as claimed in claim 15, wherein said steps 

2 (b) and (c) of redirecting comprises scrutinizing information packets on said 

3 network and selecting information packets destined for said mobile computing 

4 device . 
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